package com.ruoyi.system.api.domain;

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.ruoyi.common.core.annotation.Excel;
import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;

import java.io.Serializable;
import java.util.Date;

/**
 * 自定义操作日志记录对象 sys_oper_api_log
 *
 * @author lcj
 * @date 2025-05-16
 */
@Data
@TableName("sys_oper_api_log")
public class SysOperApiLog implements Serializable{

    private static final long serialVersionUID = 1L;


    /** 日志主键 */
    private Long operId;

    /** 模块标题 */
    @Excel(name = "模块标题")
    private String title;

    /** 业务类型（0查询 1新增 2修改 3删除） */
    @Excel(name = "业务类型", readConverterExp = "0=查询,1=新增,2=修改,3=删除")
    private Integer businessType;

    /** 方法名称 */
    @Excel(name = "方法名称")
    private String method;

    /** 请求方式 */
    @Excel(name = "请求方式")
    private String requestMethod;

    /** 操作类别（0其它 1教师端 2学生端） */
    @Excel(name = "操作类别", readConverterExp = "0=其它,1=教师端,2=学生端")
    private Integer operatorType;

    /** 操作人员 */
    @Excel(name = "操作人员")
    private String operName;

    /** 操作人员id */
    @Excel(name = "操作人员id")
    private String userId;

    /** 请求URL */
    @Excel(name = "请求URL")
    private String operUrl;

    /** 主机地址 */
    @Excel(name = "主机地址")
    private String operIp;

    /** 操作地点 */
    @Excel(name = "操作地点")
    private String operLocation;

    /** 请求参数 */
    @Excel(name = "请求参数")
    private String operParam;

    /** 返回参数 */
    @Excel(name = "返回参数")
    private String jsonResult;

    /** 操作状态（0正常 1异常） */
    @Excel(name = "操作状态", readConverterExp = "0=正常,1=异常")
    private Integer status;

    /** 错误消息 */
    @Excel(name = "错误消息")
    private String errorMsg;

    /** 操作时间 */
    @JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")
    @Excel(name = "操作时间", width = 30, dateFormat = "yyyy-MM-dd")
    private Date operTime;

    /** 消耗时间 */
    @Excel(name = "消耗时间")
    private Long costTime;

    /** 学校id */
    @Excel(name = "学校id")
    private String schoolId;

    /** 自定义日志地址id */
    @Excel(name = "自定义日志地址id")
    private String configId;

    /** 手机号 */
    @Excel(name = "手机号")
    private String mobile;

    /**
     * 学校名称
     */
    @TableField(exist = false)
    private String schoolName;


}
